// WARNING: This output format is intended for human consumers only
// and is subject to change without notice. Knock yourself out.
fn foo() -> i32 {
    let mut _0: i32;                     // return place in scope 0 at main.rs:4:19: 4:22
    let mut _1: (i32, bool);             // in scope 0 at main.rs:5:5: 5:10

    bb0: {
        _1 = CheckedAdd(const 5_i32, const 6_i32); // scope 0 at main.rs:5:5: 5:10
        assert(!move (_1.1: bool), "attempt to compute `{} + {}`, which would overflow", const 5_i32, const 6_i32) -> bb1; // scope 0 at main.rs:5:5: 5:10
    }

    bb1: {
        _0 = move (_1.0: i32);           // scope 0 at main.rs:5:5: 5:10
        return;                          // scope 0 at main.rs:6:2: 6:2
    }
}

// MIR FOR CTFE
fn foo() -> i32 {
    let mut _0: i32;                     // return place in scope 0 at main.rs:4:19: 4:22
    let mut _1: (i32, bool);             // in scope 0 at main.rs:5:5: 5:10

    bb0: {
        _1 = CheckedAdd(const 5_i32, const 6_i32); // scope 0 at main.rs:5:5: 5:10
        assert(!move (_1.1: bool), "attempt to compute `{} + {}`, which would overflow", const 5_i32, const 6_i32) -> bb1; // scope 0 at main.rs:5:5: 5:10
    }

    bb1: {
        _0 = move (_1.0: i32);           // scope 0 at main.rs:5:5: 5:10
        return;                          // scope 0 at main.rs:6:2: 6:2
    }
}

fn main() -> () {
    let mut _0: ();                      // return place in scope 0 at main.rs:8:11: 8:11
    let _1: i32;                         // in scope 0 at main.rs:9:5: 9:10

    bb0: {
        _1 = foo() -> bb1;               // scope 0 at main.rs:9:5: 9:10
                                         // mir::Constant
                                         // + span: main.rs:9:5: 9:8
                                         // + literal: Const { ty: fn() -> i32 {foo}, val: Value(<ZST>) }
    }

    bb1: {
        return;                          // scope 0 at main.rs:10:2: 10:2
    }
}
